package com.library.books.domain.vo;

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.library.common.annotation.Excel;
import com.library.common.core.serialize.DesensitizeSerialize;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

import java.math.BigDecimal;
import java.util.Date;

/**
 * @ClassName: BorrowRecordVo
 * @Description: 借阅记录
 * @Author: hb
 * @Date: 2024/10/22
 */
@Data
public class BorrowRecordVo {

    /** id */
    @ApiModelProperty("id")
    private Long borrowRecordId;

    /** 借阅id */
    @ApiModelProperty("借阅id")
    private Long borrowId;

    /** 书籍副本id */
    @ApiModelProperty("书籍副本id")
    private Long booksCopyId;

    /** 借阅人卡号 */
    @ApiModelProperty("借阅人卡号")
    @Excel(name = "借阅人卡号")
    private String borrowCard;

    /** 借归续时间 */
    @ApiModelProperty("借归续时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "借归续时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date borrowRecordTime;

    /** 续借天数 */
    @ApiModelProperty("续借天数")
    @Excel(name = "续借天数")
    private String borrowRecordDays;

    /** 类型：0：借阅，1：归还，2：续借 */
    @ApiModelProperty("类型：0：借阅，1：归还，2：续借")
    @Excel(name = "借阅记录类型" , dictType = "borrow_record_type")
    private String borrowRecordType;


    /** 创建人id */
    @ApiModelProperty("创建人id")
    @TableField(fill = FieldFill.INSERT)
    private Long createId;

    /** 创建者 */
    @ApiModelProperty("创建者")
    @Excel(name = "创建者")
    @TableField(fill = FieldFill.INSERT)
    private String createBy;

    /** 创建时间 */
    @ApiModelProperty("创建时间")
    @Excel(name = "创建时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    /** 前端查询条件 */
    private Date createStartTime;
    private Date createEndTime;

    /** 借阅天数 */
    @ApiModelProperty("借阅天数")
    @Excel(name = "借阅天数")
    private Long borrowDays;

    /** 续借天数 */
    @ApiModelProperty("续借天数")
    @Excel(name = "续借天数")
    private String borrowRenewDays;

    /** 续借时间 */
    @ApiModelProperty("续借时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "续借时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date borrowRenewTime;

    /** 归还时间 */
    @ApiModelProperty("归还时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "归还时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date borrowReturnTime;

    /** 应还时间 */
    @ApiModelProperty("应还时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "应还时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date borrowShouldReturnTime;

    /** 借阅状态：0：正常，1：逾期，2：已归还 */
    @ApiModelProperty("借阅状态")
    @Excel(name = "借阅状态" , dictType = "borrow_status")
    private String borrowStatus;


    /** 学号 */
    @ApiModelProperty("学号")
    @Excel(name = "学号")
    private String studentNumber;

    /** 卡号 */
    @ApiModelProperty("卡号")
    @Excel(name = "卡号")
    private String studentCardNumber;

    /** 学生身份证号 */
    @ApiModelProperty("学生身份证号")
    @Excel(name = "学生身份证号")
    @JsonSerialize(using = DesensitizeSerialize.class)
    private String studentIdCard;

    /** 学生姓名 */
    @ApiModelProperty("学生姓名")
    @Excel(name = "学生姓名")
    private String studentName;

    /** 学生昵称 */
    @ApiModelProperty("学生昵称")
    @Excel(name = "学生昵称")
    private String studentNick;


    /** ISBN号 */
    @ApiModelProperty("ISBN号")
    @Excel(name = "ISBN号")
    private String booksIsbn;

    /** 书籍名称 */
    @ApiModelProperty("书籍名称")
    @Excel(name = "书籍名称")
    private String booksName;

    /** 书籍类别 */
    @ApiModelProperty("书籍类别")
    @Excel(name = "书籍类别")
    private String booksType;

    /** 书籍作者 */
    @ApiModelProperty("书籍作者")
    @Excel(name = "书籍作者")
    private String booksAuthor;

    /** 出版社 */
    @ApiModelProperty("出版社")
    @Excel(name = "出版社")
    private String booksPublisher;

    /** 内容简介 */
    @ApiModelProperty("内容简介")
    @Excel(name = "内容简介")
    private String booksSynopsis;

    /** 封面图片 */
    @ApiModelProperty("封面图片")
    @Excel(name = "封面图片")
    private String booksCoverPhoto;

    /** 小类索书号 */
    @ApiModelProperty("小类索书号")
    @Excel(name = "小类索书号")
    private String booksCopyLicense;

    /** 书架名称：A书架 */
    @ApiModelProperty("所属书架")
    @Excel(name = "所属书架")
    private String bookShelfName;
}
